hvm: Add ACPI fixed sleep button
authorKeir Fraser <keir.fraser@citrix.com>
Wed, 20 Jan 2010 20:34:19 +0000 (20:34 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Wed, 20 Jan 2010 20:34:19 +0000 (20:34 +0000)
Signed-off-by: Paul Durrant <paul.durrant@citrix.com>
tools/firmware/hvmloader/acpi/static_tables.c
xen/arch/x86/domctl.c
xen/arch/x86/hvm/pmtimer.c
xen/include/public/domctl.h

index e040c56187530504182fb0f612f367374dd7a7ae..c7faee86358b96a635e9cfbc656e44dcfe8fb0b3 100644 (file)
@@ -68,7 +68,7 @@ struct acpi_20_fadt Fadt = {
     .p_lvl2_lat = 0x0fff, /* >100,  means we do not support C2 state */
     .p_lvl3_lat = 0x0fff, /* >1000, means we do not support C3 state */
     .iapc_boot_arch = ACPI_8042,
-    .flags = (ACPI_PROC_C1 | ACPI_SLP_BUTTON |
+    .flags = (ACPI_PROC_C1 |
               ACPI_WBINVD |
               ACPI_FIX_RTC | ACPI_TMR_VAL_EXT),
 
index 94673aa081c432dd2ad488e8c217ceed6f20af45..b59bc9b6c6a52123a15d886c402153cda32ecebe 100644 (file)
@@ -727,6 +727,19 @@ long arch_do_domctl(
         }
         break;
 
+        case XEN_DOMCTL_SENDTRIGGER_SLEEP:
+        {
+            extern void hvm_acpi_sleep_button(struct domain *d);
+
+            ret = -EINVAL;
+            if ( is_hvm_domain(d) ) 
+            {
+                ret = 0;
+                hvm_acpi_sleep_button(d);
+            }
+        }
+        break;
+
         default:
             ret = -ENOSYS;
         }
index 0a0b326efe77099cbf9f5d58680b9f304807014b..48fe26ac87b3514cf324de9f2af595cd7dc4009d 100644 (file)
 #define TMR_STS    (1 << 0)
 #define GBL_STS    (1 << 5)
 #define PWRBTN_STS (1 << 8)
+#define SLPBTN_STS (1 << 9)
 
 /* The same in PM1a_EN */
 #define TMR_EN     (1 << 0)
 #define GBL_EN     (1 << 5)
 #define PWRBTN_EN  (1 << 8)
+#define SLPBTN_EN  (1 << 9)
 
 /* Mask of bits in PM1a_STS that can generate an SCI. */
-#define SCI_MASK (TMR_STS|PWRBTN_STS|GBL_STS) 
+#define SCI_MASK (TMR_STS|PWRBTN_STS|SLPBTN_STS|GBL_STS) 
 
 /* SCI IRQ number (must match SCI_INT number in ACPI FADT in hvmloader) */
 #define SCI_IRQ 9
@@ -68,6 +70,15 @@ void hvm_acpi_power_button(struct domain *d)
     spin_unlock(&s->lock);
 }
 
+void hvm_acpi_sleep_button(struct domain *d)
+{
+    PMTState *s = &d->arch.hvm_domain.pl_time.vpmt;
+    spin_lock(&s->lock);
+    s->pm.pm1a_sts |= SLPBTN_STS;
+    pmt_update_sci(s);
+    spin_unlock(&s->lock);
+}
+
 /* Set the correct value in the timer, accounting for time elapsed
  * since the last time we did that. */
 static void pmt_update_time(PMTState *s)
index 5f29ded1abfa62b2cde7e66fa47c43064a6fca61..6d00a84df579ce4cb2e0efc42b073763618f7080 100644 (file)
@@ -439,6 +439,7 @@ DEFINE_XEN_GUEST_HANDLE(xen_domctl_real_mode_area_t);
 #define XEN_DOMCTL_SENDTRIGGER_RESET  1
 #define XEN_DOMCTL_SENDTRIGGER_INIT   2
 #define XEN_DOMCTL_SENDTRIGGER_POWER  3
+#define XEN_DOMCTL_SENDTRIGGER_SLEEP  4
 struct xen_domctl_sendtrigger {
     uint32_t  trigger;  /* IN */
     uint32_t  vcpu;     /* IN */